草庐IT

php - Cakephp 类注册表::初始化

全部标签

ruby - 在 Ruby 中初始化常量的正确方法是什么?

我有一个简单的类,它定义了一些常量,例如:moduleFooclassBarBAZ="bof"...在我告诉Rake运行我所有的Test::Unit测试之前,一切都是小狗和彩虹。当它发生时,我会收到警告:bar.rb:3:warning:alreadyinitializedconstantBAZ我的习惯是通过使常量初始化有条件来避免这些警告,例如:...BAZ="bof"unlessconst_defined?:BAZ...这似乎解决了问题,但有点乏味,而且我从未见过其他人以这种方式初始化常量。这让我觉得我可能做错了。有没有更好的方法来初始化不会产生警告的常量?更新:通过更详细地说明我

ruby-on-rails - 测试 Rails API 以使用 devise 进行注册。错误 : "Missing ' confirm_success_url' parameter.“

我正在尝试使用devise和devise_token_auth用于在我的应用中进行身份验证。我正在重写注册Controller,如下所示:moduleOverridesclassRegistrationsController:createdefsign_up_paramsparams.require(:user).permit(:email,:password,:password_confirmation,:name,:nickname)endendend我还使用swaggerdocsapi发送我的参数如下:swagger_api:createdosummary"Signupanewu

ruby-on-rails - 路由错误 - 未初始化的常量 UsersController? omn​​iauth-facebook

所以我有这个应用程序使用omniauth-facebook来验证用户,一个新用户在sessionController中创建:classSessionsController然后它命中用户模型:classUser然后在我的用户Controller中,我有类似这样的东西来显示用户配置文件:classUserController在show.html.erb中我有这样的东西:,但我收到以下错误:路由错误-未初始化的常量UsersController我的路线文件:Bummerang::Application.routes.drawdoresources:users,:only=>:showroot

ruby - 为什么在初始化时不使用 setter 方法?

最近我一直在阅读“Ruby中的实用面向对象设计”,我注意到最佳实践之一是使用访问器方法而不是直接获取@instance_variable。例如:classFooattr_accessor:bardefinitialize(my_argument)@bar=my_argumentend#bad#deflorem_ipsum#@bar*999#end#gooddeflorem_ipsumbar*999endend让事情保持干燥是有意义的,并且,以防万一我需要在实际获取它的值之前以某种方式处理@bar。但是,我注意到initialize方法直接设置了@bar实例变量的值:classFooat

ruby - 在 Mixins 中初始化实例变量

是否有任何干净的方法来初始化旨在用作Mixin的模块中的实例变量?例如,我有以下内容:moduleExampledefon(...)@handlers||={}#dosomethingwith@handlersenddefall(...)@all_handlers||=[]#dosomethingwith@all_handlersenddefunhandled(...)@unhandled||=[]#dosomethingwithunhandledenddefdo_something(..)@handlers||={}@unhandled||=[]@all_handlers||=[]#

ruby 1.9.3 不能使用 open3(未初始化的常量 ConfigureController::Open3)

该项目在Ruby1.9.2中运行良好,但我想使用1.9.3。此行在1.9.2中运行良好:o,e,s=Open3.capture3("echoa;sort>&2",:stdin_data=>"foo\nbar\nbaz\n")但是在1.9.3中,我得到了未初始化常量ConfigureController::Open3我必须安装模块还是什么?谢谢! 最佳答案 您是否在源文件的顶部require'open3'?有可能之前,它是您需要的其他东西所必需的,但现在在1.9.3中则不是。您可能需要明确要求它。

ruby-on-rails - 如何从初始化器扩展一个类并在开发环境中重新加载它?

我通过包含一个模块来扩展一个类(在插件中),这是在初始化程序中完成的。require'qwerty/core/user'User.send:include,Qwerty::Core::Extensions::User但是在开发过程中,在每次请求之前(以及在控制台中调用reload!之后)所有模型都会重新加载,但由于初始化器不会再次运行,所以模块不包含在内。留下带有“缺失部分”的模型。因为模型在插件中,所以将代码直接包含在类中似乎不是明智的做法,这将是通常的方法。现在我只是简单地添加了一个before_filter,它包含了开发环境中的模块。但是我有复制/粘贴并且在初始化程序和应用程序C

ruby-on-rails - Rails - Devise Gem 删除注册和忘记密码模块

我使用Rails4和Devisegem进行用户身份验证,在我的项目中也可以很好地使用Devisegem。但我想删除Signup和ForgotPassword模块的功能。为了删除sign_up,在config/routes.rb文件中使用skip选项,例如,devise:users,:skip=>:registration它删除了sign_up模块也截断了路径生成。这很好。但同样,如果我为Forgotpassword添加此选项devise:users,:skip=>:recoverordevise:users,:skip=>:recoverable那是行不通的。我需要以相同的方法隐藏这两

ruby - 用 block 初始化对象

是否可以像下面这样用block初始化一个对象?classFooattr_reader:bar,:bazdefinitialize(bar,baz)@bar,@baz=bar,bazendendFoo.newdo|bar,baz|#somelogictobeimplemented#@bar,@baztobeassignedend 最佳答案 当然,你可以在initialize中yield,这没什么特别的:classFooattr_accessor:bar,:bazdefinitializeyieldselfendendFoo.newdo

ruby - 如何将 FactoryGirl 与在初始化方法中采用散列的模型一起使用?

看起来很简单,但一直无法弄清楚如何让它发挥作用。在模型.rb中:defModelattr_accessor:width,:heightdefinitializeparams@width=params[:width]@height=params[:height]...在工厂文件models.rb中:FactoryGirl.definedofactory:modeldoheight5width7endend在工厂方法中设置属性会抛出错误wrongnumberofarguments(0for1)在没有Rails的情况下使用Ruby1.9.3,使用Factory.build。FactoryGi